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(57) A window system of the kind used in personal 
computers is cpornblo in a portable information terminal 
which docs not hnvc a sufficient processing capability 
by having input inlormaiion. such as a key input from an 
operator. gcncrHicd in a portable information terminal 
210 sent to a rcmoic supporting sen/er 240 where it ex- 
ecutes or simulates an arbitrary window system which 
is free from rcstr ictton of functions to generate a render- 
ing image The supporting server then converts the ren- 
dering imago to an image suitable to the portable infor- 
mation terminal and sends it back to the portable infor- 
mation terminal 21 0 as a rendering instruction. The port- 
able information terminal 210 receives the rendering in- 
struction of this optimised image for display 
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Description 

This invention relates to a remote control method 
and. in particular, to an improved remote control methcxJ 
in which resources required lor a machine to be remote 
controlled are reduced. 

An OS (Operating System) providing a GUI (Graph- 
ic User Interface) and capable of file processing has 
been so far operable on a portable terminal such as a 
notebook PC. 

However, a certain degree of machine power was 
required for a portable terminal in order to run such OS, 
For example. Windows 95 (Windows 95 is a trademark 
of Microsoft) requires provision of a CPU which is equal 
to or above i486SX, a memory larger than 8MB. a hard 
disk larger than 75 MB and a video display adapter hav- 
ing a resolution above the VGA. 

On the other hand, a portable terminal, such as a 
smartphone. which has a small memory capacity and is 
provided only with a telephone function and an output 
function of a simple display, etc.. including "Datascope" 
of Kyocera and "Pinocchio" of Panasonic, can only op- 
erate a special chip OS and can not use a general pur- 
pose OS. 

There have been several operating systems, such 
as the above chip OS. specialised for and operable sole- 
ly on a portable information terminal. 

However, they are accompanied with a problem that 
the function is limited due to the limited machine power, 
memory capacity and display capability and they are un- 
able to execute a high level application which is opera- 
ble on a general purpose OS as used in converitional 
PC's. 

On the other hand: a portable terminal which can 
operate a general purpose OS involves a problem that 
down-sizing would involve many restrictions and the 
cost would be increased. 

Further because the window system of the portable 
information terminal is specialised to such terminal, an 
application has to be often designed and developed 
solely for such window system and an application used 
in home or office can not be used in such terminal. 

In addition, while a portable information terminal is 
often carried along in a brief case, etc., by its nature, a 
danger was accompanied in which important data was 
lost by accident because data of an application special- 
ised for such portable information terminal is stored in 
a memory of such terminal. 

It is an object of this invention to provide a system 
which is capable of executing a general purpose OS as 
used in a conventional PC and a high level application 
operating on such OS in a machine having a limited re- 
sources. 

It is one of other objects in one mode of this inven- 
tion to provide a small sized portable terminal which can 
provide a high functbn with a low cost. 

It is one of other objects in one mode of this inven- 
tion to provide a portable information terminal which can 



execute an application used in home and office, etc. 

It IS one of other objects in one mode of this inven- 
tion to provide a portable information terminal which has 
a low probability of losing data. 
5 It is one of other objects in one mode of this inven- 
tion to reduce the work of installing a remote control soft- 
ware which was generated in the side of remote control- 
ling terminal for enabling a consolidated control of a sys- 
tem. 

10 It is one of other objects in one mode of this inven- 
tion to provide a system which is not affected by the type 
of a remote controlling terminal for realising a common 
operability. 

It is one of other objects in one mode of this inven- 
ts tion to reduce the usage of resources of a remote con- 
trolling terminal lor reducing the hardware requirement 
to enable a general purpose OS and a general purpose 
application to be used. 

It is one of other objects in one mode of this inven- 
20 lion to provide a high speed remote control system 
which reduces the volume of communication data be- 
tween a remote controlling machine and a remote con- 
trolled machine in remote control operation. 

It is one of other objects in one mode of this inven- 
tion to provide a remote control system which can trans- 
mit data in an optimum form to a remote controlling ma- 
chine in remote control operation. 

It is one of other objects in one mode of this inven- 
tion to provide a remote control system which can simul- 
taneously support a plurality of remote controlling ma- 
chines in rerrxjte control operation. 

Input information, such as a key input from an op- 
erator generated in a remote controlling machine is 
transmitted to a remote location supporting server which 
executes or simulates an arbitrary window system which 
is free from restriction of function to generate a render- 
ing image. The supporting server then converts the ren- 
dering image to an image which is suitable to the remote 
controlling machine and returns it to the remote control- 
ling machine as a rendering instruction. The remote con- 
trolling machine receives the rendering instruction of 
this optimised image and displays it. 

Because this window system actually operates on 
the supporting server, a window system which is widely 
used in personal computers, etc.. may be used as it is 
and also an application for personal computers may be 
used as it is. 

In one mode of this invention, a plurality ol remote 
controlling machines can be simultaneously supported 
and, in response to processing capability specifying in- 
formation transmitted from individual remote controlling 
machine, a rendering instruction is transmitted after 
conversion to a form which is optimum to each individual 
remote controlling machine. 

In one of other modes of this invention, a method is 
provided for renrcte controlling resources retained by a 
server existing on a network from a terminal which has 
an input device and a display device, comprising the 
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Steps of; 

(a) accessing said server via said network. 

(b) transmitting a signal generated Irom the input 
device of said ternninal to said server as input infor- 
mation, 

(c) receiving in said server side the input infornnation 
transmitted from said terminal side and analysing 
the content of the input infomnation. 

(d) generating first rendering image data consisting 
of a first number of bits per picture element. 

(e) convening said first rendering image data to sec- 
ond rendering image data consisting of a second 
number of bits per picture element less than the first 
number ol bits. 

(f ) transmitting a rendering instruction including said 
second rendering image from said server side to 
said terminal side, 

(g) analysing the rendering instruction transmitted 
from the server side on said terminal side, and 

(h) generating image data to be displayed in a dis- 
play screen ol said terminal according to the content 
of the analysed rendering instruction. 

In one of other modes of this invention, a method is 
provided for remote controlling resources retained by a 
server existing on a network from a terminal which has 
an input device and a display device, comprising the 
steps of; 

(a) transmitting a connection request from a first ter- 
minal of said plurality of terminals to said server via 
said network 

(b) starting a shell process in said server in re- 
sponse to the connectbn request from said first ter- 
minal, 

(c) transmitting processing capability specifying in- 
formation from said first terminal to said sender, 

(d) transmitting a signal generated Irom an input de- 
vice of said first terminal to said sen/er as input in- 
formation, 

(e) receiving the input information transmitted from 
said terminal side in said server side and analysing 
the content of the input information, 

(f) generating first rendering innage data based on 
the content of the analysed input information, 



{g) converting said first rendering image data to sec- 
ond rendering image data according to said 
processing capability specifying information. 

5 (h) transmitting a rendering instruction including 
said second rendering image Irom said server side 
to said terminal side, 

(i) analysing the rendering instruction transmitted 
from the server side in said terminal side, 

(j) generating image data to be displayed in a dis- 
play screen of said terminal according to the content 
of the analysed rendering instruction. 

In one of other modes ol this invention, a method is 
provided for renrtote controlling resources retained by a 
server existing on a network from a terminal which has 
an input device and a display device, comprising the 
steps of; 

(a) receiving the input information transmitted from 
said terminal side, 

(b) analysing the input information, 

(c) generating first rendering image data consisting 
of a first number of bits per picture element based 
on the content of the analysed input information, 

(d) converting said first rendering image data to sec- 
ond rendering image data consisting of a second 
number of bits per picture element less than the first 
number of bits, 

(e) transmitting a rendering instruction including 
said second rendering image Irom said server side 
to said terminal side. 

In one of other modes of this invention, a method is 
provided for renxDte controlling resources retained by a 
server existing on network from a terminal which has an 
input device and a display device, comprising the steps 
of; 

(a) starting a shell process in response to a connec- 
tion request from a first terminal of said plurality of 
terminals, 

(b) receiving input information transmitted from said 
terminal side, 

(c) analysing the input information, 

(d) generating first rendering image data consisting 
of a first number of bits per picture element based 
on the content of the analysed input information, 
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(e) converting said first rendering image data to sec- 
ond rendering image data consisting ol a second 
number o\ bits per picture element less than the first 
number ol bits, 

(f) transmitting a rendering instruction including said 
second rendering image from said server side to 
said terminal side. 

In one ol other modes of this invention, a method is 
provided for remote controlling resources retained by a 
server existing on a network from terminal which has an 
input device and a display device, comprising the steps 
of. 

(a) receiving a processing capability specifying in- 
tornrviicn transmitted from said terminal, 

(b) fcccrving input information transmitted from said 
Icrmir^Hl 

(c) nnnfys ng the input information transmitted from 
saic Icmnal 

(d) gcrcr:jting first rendering image data based on 
tno conion! of the analysed input information, 

(e) converting said first rendering image data to sec- 
ond ronrtoring innage data according to said 
processing capability specifying information. 

(f ) transmitting a rendering instruction including said 
second rendering image from said server side to 
said terminal side. 

In one of other modes of this invention, the process- 
ing capability specifying information is either one of; 

(a) maximum resolution information of a logical 
screen. 

(b) maximum resolution information of a physical 
screen. 

(c) bits per pcture element information. 

(d) colour palette information, 

(e) compression/decompression capability infor- 
mation, of said terminal. 

In one of other modes of this invention, a method is 
provided for remote controlling resources retained by a 
server existing on a network from a terminal which has 
an input device and a display device, comprising the 
steps of; 

(a) starting a shell process in response toa connec- 



tion request from a first terminal of said plurality of 
termir^ls, 

(b) receiving processing capability specifying infor- 
5 mation transmitted from said terminal side. 

(c) receiving input information transmitted from said 
terminal side, 

10 (d) analysing the input information, 

(e) generating first rendering image data based on 
the content of the analysed input information, 

J5 (f) converting said first rendering image data to sec- 
ond rendering image data according to said 
processing capability specifying information. 

(g) transmitting a rendering instruction including 
20 said second rendering image from said server side 
to said terminal side. 

In one of other modes of this invention, a system is 
provided which comprises a server existing on a net- 
work, and a terminal having an input device and a dis- 
play device capable of remote controlling resources of 
said server retained by said server, comprising: 

(a) a terminal; 

30 

(a-1) accessing said server via said network, 

(a-2) transmitting a signal generated from the 
input device of said terminal to said server as 
35 input information, 

(a-3) analysing a rendering instruction trans- 
mitted from the server side, 

40 (a-4) generating image data to be displayed in 

a display screen of said terminal according to 
the content of the analysed rendering instruc- 
tion, and 

45 (b) a server; 

(b-1) receiving input information transmitted 
from said terminal side and analysing the con- 
tent of the input information, 

so 

(b-2) generating first rendering image data con- 
sisting of a first number of bits per picture ele- 
ment based on the content of the analysed in- 
put information, 

55 

(b-3) converting said first rendering image data 
to second rendering image data consisting of a 
second number of bits per picture element less 
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than the first number of bits. 

(b-4) transmitting a rendering instruction in- 
cluding said second rendering image from said 
server side to said terminal side. 

In one of other modes of this invention, a system is 
provided which comprises a server existing on a net- 
work, and a plurality of terminals having an input device 
and a display device capable of remote controlling re- 
sources of said server retained by said server, compris- 
ing; 

(a) a plurality of terminals; 

(a-1 ) transmitting a connection request to said 
server via said network, 

{a-2) transmitting processing capability speci- 
fying information to said server, 

(a-3) transmitting a signal generated from the 
input device to said server as input information, 

(a-4) analysing a rendering instruction trans- 
mitted from the server side, 

(a-5) generating image data to be displayed in 
a display screen according to the content of the 
analysed rendering instruction, and 

(b) a server: 

(b-1) starting a shell process in response to a 
connection request from the terminal side. 

(b-2) receiving input information transmitted 
from said terminal side and analysing the con- 
tent of the input information, 

{b-3) generating first rendering image data 
based on the content of the analysed input in- 
formation. 

(b-4) converting said first rendering image data 
to second rendering image data according to 
said processing capability specifying Intorma- 
lion, 

(b-5) transmitting a rendering instruction in- 
cluding said second rendering innage from said 
server side to said terminal side. 

In one of other modes of this invention, a server is 
provided which exists on a network and is remote con- 
trolled from a terminal which has an input device and a 
display device, comprising; 



(a) an input information receiving part for receiving 
input information transmitted from said terminal 
side, 

5 (b) an input information analysing part for analvsing 
the input information. 

(c) an image rendering engine tor generating first 
rendering image data consisting of a first number of 

10 bits per picture element based on the content of the 
analysed input information, 

(d) a rendering instruction monitoring part for con- 
verting said first rendering image data to second 

IS rendering image data consisting of a second 
number of bits per picture element less than the first 
number of bits. 

(e) a rendering instruction transmitting part for 
20 transmitting a rendering instruction including said 

second rendering image from said server side to 
said terminal side. 

In one of other modes of this invention, a server is 
2S provided which exists on a network and is remote con- 
trolled from a terminal which has an input device and a 
display device, comprising: 

(a) an input information receiving part; 

30 

(a-1) starting a shell process in response to a 
connection request from a first terminal of said 
plurality of terminals and, 

35 (a-2) receiving input information transmitted 

from said first terminal, 

(b) an input information analvsing part for analysing 
the input information, 

40 

(c) an image rendering engine for generating 
first rendering image data consisting of a first 
number of bits per picture element based on the 
content of the analysed input information. 

45 

(d) a rendering instruction monitoring part for 
converting said first rendering image data to 
second rendering image data consisting of a 
second number of bits per picture element less 

so than the first number of bits, 

(e) a rendering instruction transmitting part for 
transmitting a rendering instruction including 
said second rendering image from said server 

ss side to said terminal side. 

In one of other modes of this invention, a server is 
provided which exists on a network and is remote con- 
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ifoHcd ((om a terminal which has an input device and a 
tliNpUy riovice comprising; 

H) nn input information receiving part:- 

(rt-i ) receiving processing capability specifying 
iniormation transmitted Irom said terminal, and 

{H-2) receiving input information transmitted 
Irom said first terminal, 



10 



(b) an input information analysing part for analysing 
tic ^pui information, 

^:^ fin irrwge rendering engine for generating first 
fcnoomq ttTiage data based on the content of the 
r^rnty^cc npji intormation, 

13 /1 »c<xJcring instruction monitoring part for con- 
WL-M»»g viO iirst rendering image data to second 20 
iLf o^Miig iirbiL^o data according to said processing 
cni>iL» i^y specifying information, 

iC} .1 »cndci mg instruction transmitting part for 
tMHcmiring .j fcndcring instruction including said 2S 
iocotk: rcndoring image from said server side to 
s^»c lo mi'v*! Side 



transmitting a rendering instruction including said 
second rendering image from said sen/er side to 
said first terminal side. 

In one of other modes of this invention, a recording 
medium is provided which stores therein a remote con- 
trolled program executed by said server for remote con- 
trolling resources retained by a server existing on a net- 
work from a terminal which has an input device and a 
display device, comprising; 

(a) a program code instructing said server to receive 
input information transmitted from said terminal 
side, 

(b) a program code instructing said server to ana- 
lyse the input information, 

(c) a program code instructing said server to gen- 
erate first rendering image data consisting of a first 
number of bits per picture element, 

(d) a program code instructing said server to con- 
vert said first rendering image data to second ren- 
dering image data consisting of a second number 
of bits per picture element less than the first number 
of bits. 



li nn^ of nihof modes of this invention, a server is 
provi.-i*-^ *^*nrh ouists on a network and is remote con- 
trolled ifcxr terminal which has an input device and a 
display device comprising: 

(a) npul information receiving part; 

(rt t i staling a shell process in response to a 
connection request from a first terminal of said 
piLfrti ly of terminals and, 

(a 2» receiving processing capability specifying 
information transmitted from said first terminal, 

(a-3) receiving input information transmitted 
Irom said lirst terminal. 

(b) an nput information analysing part for analysing 
the input information, 

(c) an linage rendering engine for generating first 
rendering image data based on the content of the 
analysed rnput information, 

(d) a rendering Instruction monitoring part for con- 
verting said first rendering Image data to second 
rendering image data according to said processing 
capability specifying information, 

(e) a rendering instruction transmitting part for 
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(e) a program code instructing said server to trans- 
mit a rendering instruction including said second 
rendering image from said server side to said ter- 
minal side. 

In one of other modes of this invention, a recording 
medium is provided which stores therein a remote con- 
trolled program executed by said server for remote con- 
trolling resources retained by a server existing on a net- 
work from a terminal which has an input device and a 
display device, comprising: 

(a) a program code instructing said server to start 
a shell process in response to a connection request 
from a first terminal of said plurality of terminals. 

(b) a program code instructing said sen/er to receive 
input information transmitted from said first terminal 
side, 

(c) a program code instructing said server to ana- 
lyse the input information, 

(d) a program code instructing said server to gen- 
erate first rendering image data consisting of a first 
number of bits per picture element based on the 
content of the analysed input information, 

(e) a program code instructing said server to con- 
vert said first rendering image data to second ren- 
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dering image data consisting of a second number 
of bits per picture element less than the first number 
of bits. 

(f) a program code instructing said server to trans- 
mit a rendering instruction including said second 
rendering image from said server side to said first 
terminal side. 

In one of other modes of this invention, a recording 
medium is provided which stores therein a remote con- 
trolled program executed by said server for remote con- 
irolling resources retained by a server existing on a net- 
work from a terminal which has an input device and a 
dispiny device, comprising; 

H M program code instructing said server to receive 
pfoccssing capability specifying information trans- 
nitixJ Irom said terminal, 

(bi piogiam code instructing said server to receive 
input inlormation transmitted from said terminal, 

ic) ii p'ogram code instructing said server to ana- 
h/sc the irpul information, 

(di program code instructing said server to gen- 
cfHic tirsi rendering image data based on the con- 
i.-»n! o( iho analysed input information. 

(c) rt program code instructing said sen/er to con- 
vert said first rendering image data to second ren- 
dering im^ige data according to said processing ca- 
pabilily specifying information, 

(I) rt program code instructing said server to trans- 
mit a rendering instruction including said second 
rendcrng image from said server side to said first 
terminal side 

In one of other modes of this invention, a recording 
medium is provided which stores therein a remote con- 
trolled program executed by said server for remote con- 
trolling resources retained by a server existing on a net- 
work from a terminal which has an input device and a 
display device, comprising; 

(a) a program code instructing said sen/er to start 
a shell process in response to a connection request 
from a first terminal of said plurality of terminals, 

(b) a program code instructing said server to receive 
processing capability specifying information trans- 
mitted from said first terminal, 

(c) a program code instructing said server to receive 
input information transmitted from said first termi- 
nal. 



(d) a program code instructing said server to ana- 
lyse the input information, 

(e) a program code instructing said server to gen- 
s erate first rendering image data based on the con- 
lent of the analysed input information. 

(f) a program code instructing said server to convert 
said first rendering image data to second rendering 

10 image data according to said processing capability 
specifying information, 

(g) a program code instructing said server to trans- 
mit a rendering instruction including said second 

IS rendering image from said server side to said first 
terminal side. 

In one of other modes of this invention, a method is 
provided for specifying a display region of size of (wx, 

20 wy) to be displayed on a display screen from image data 
constituting a logical screen having a size of (sx, sy) 
stored in a portable information terminal, characterised 
in that the region of the size of (wx. wy) is specified as 
a display region starling from a starting point which is 

2S defined as; 

ox = px(sx - wx)/((sx - 1) 

30 

oy = py(sy- wy)/(sy- 1) 

where (px, py) is a co-ordinate position of a mouse point- 
er of the portable information terminal. 
35 How the invention may be carried out will now be 
described with reference to the accompanying drawings 
in which: 

Fig. 1 is a block diagram of an embodiment of the 
hardware configuration of a remote control machine or 
a supporting sen/er 

Fig. 2 is a diagram showing an embodiment of this 
invention in operational condition. 

Fig. 3 is a block diagram showing the structure of 
portable information terminal and a supporting server in 
a preferred embodiment of this invention. 

Fig. 4 Is a flow chart showing the operational con- 
dition of a portable informalbn terminal in a preferred 
embodiment of this invention. 

Fig. 5 is a flow chart showing the operational con- 
dition of portable information terminal in a preferred em- 
bodiment of this invention. 

Fig. 6 is a flow chart showing the operational con- 
dition of supporting server in a preferred embodiment of 
this invention. 

Fig. 7 is a flow chart showing the operational con- 
dition of supporting sen/er in a preferred embodiment of 
this invention. 

Fig. 8 is a flow chart showing the operational con- 
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dilbn of a supporting server in a preferred embodiment 
of this invention- 
Fig. 9 is a flow chart showing the operational con- 
dition of a supporting server in a preferred embodiment 
of this invention- 
Fig. 10 is a flowchart showing the operational con- 
dition oi a supporting server in a preferred embodiment 
of this invention. 

Fig. 11 is a schennatic diagram showing the opera- 
tional condition of a portable information terminal and a 
supporting sen/er in a preferred embodiment of this In- 
vention. 

Fig. 1 2 is a diagram showing an embodiment of data 
conversion performed by an input information generat- 
ing part in a preferred embodiment of this invention. 

Fig. 1 3 is a diagram showing an embodiment of in- 
put information and data in a preferred embodiment of 
this invention. 

Fig. 1 4 is a diagram showing an embodiment of data 
conversion performed by an input information analysing 
part in a preferred embodiment of this invention. 

Fig. 15 is a diagram showing an embodiment of a 
rendering instruction data in a preferred embodiment of 
this invention. 

Fig. 16 is a diagram showing an example of image 
conversion in a preferred embodiment of this invention. 

Fig. 17 is a diagram showing an example of image 
conversion in a preferred embodiment of this invention. 

The embodiment of this invention is now described 
with reference to the drawings hereunder Referring to 
Fig. 1. an embodiment of hardware configuration of re- 
mote controlling machine (portable information terminal 
210) as used in this invention is schematically shown. 
A remote controlling machine 100 comprises a central 
processing unit (CPU) 1 and a memory 4. The CPU 1 
and the memory 4 are connected to a hard disk device 
1 3, an auxiliary memory device, (or a flash ROM 31 ) via 
a bus 2. A floppy disk device (or a recording medium 
such as f^O. CD-ROf^ 23, etc.) 20 is connected to the 
bus 2 via a floppy disk controller 19. 

A floppy disk (or a recording medium such as MO, 
CD-ROM. etc.) is inserted in the floppy disk device (or 
a recording medium drive device such as MO. CD-ROM, 
etc.) 20. The floppy disk, a hard disk device 13 (or a 
recording medium such as MO. CD-ROM 23. DVD) and 
a ROM 1 4 may record therein a computer program code 
for providing instructions to the CPU 1 in co-operation 
with an operating system to practice this invention, 
which instructions are executed by being loaded in the 
memory 4. The computer program may be compressed 
or divided into a plurality of pieces for recording in a plu- 
rality of media. 

The remote controlling machine 210 may be further 
provided with a user interface hardware and have a 
pointing device (mouse, track ball and joystick, etc.) 7, 
a keyboard 6 and a display 1 2 for presenting visual data 
to the user. It is also possible to connect a printer via a 
parallel port 16 and a modem via a serial port 15. The 



remote controlling machine 210 can be connected to a 
network via a serial port 15 and a modem or via a com- 
munication adapter 18 (Ethernet and token ring) for 
connmunication with other computers. 
5 A speaker 23 receives an audio signal which is D/ 
A converted (digital/analog conversion) by an audio 
controller 21 via an amplifier 22 to output as a voice. The 
audio controller 2i can also A/D convert voice informa- 
tion received from a microphone 24 to take in voice in- 
10 formation external to the system into the system. 

It will be readily understood that the remote control- 
ling machine 210 of this invention can be practised with 
a conventional personal computer (PC), a workstation, 
a notebook PC, a palm top PC. a network computer, var- 
ious home electric appliances such as a television in 
which a computer is implemented, a game machine hav- 
ing a communication function, and a communication ter- 
minal having a communication function such as a tele- 
phone device, a facsimile device, a portable telephone 
device, a PHS and an electronic notebook, or a combi- 
nation thereof. It should be understood that these com- 
ponents are exemplary given and it is not meant that all 
these components are necessarily indispensable to this 
invention. 

Particularly, as seen from the use of a smartphone. 
wrhich has a telephone function, an output function of a 
display, etc., and a send/receive function of an electron- 
ic mail including "Datascope" of Kyocera and "Pinoc- 
chio" of Panasonic, as the remote controlling machine 
210 in the preferred embodiment of this invention, the 
audio controller 21 . the amplifier 22. the speaker 23 and 
the microphone 24 required for processing a voice, the 
keyboard 6. the mouse 7 and the key board/mouse con- 
troller 5 which enable a direct input from the operator, 
the CRT 12, the display device 11 . the VRAM 9 and the 
VGA 8 for presenting visual data to the user, and various 
recording medium processing devices 1 9, 25. 27 are not 
necessarily required components. It is sufficient for the 
keyboard 6. the mouse 7 and the keyboard/mouse con- 
troller 5 to have input means for performing a remote 
operation practically 

Each component of the remote controlling machine 
210 and various modifications including combining a 
plurality of machines and distributing functions to each 
to practice this invention should be readily obvious to 
those skilled in the art and such modifications are In- 
cluded in the concept of this invention. 

The supporting sen/er 240 used in this inventbn 
may be also implemented by the hardware configuration 
shown in Fig. 1 in the same manner as the remote con- 
trolling machine 210. 

In other words, it is also sufficient for the supporting 
server 240 to be provided with a function of receiving 
transmitted input information and converting it to a ren- 
dering instruction for sending, and a function of storing 
remote controlling and remote controlled softwares and 
sending the remote controlling software, so that it should 
be readily understood that the server 240 may be also 



20 



2B 



30 



35 



40 



45 



SO 



15 



EP 0 889 402 A2 



16 



implemented by a communication terminal having a 
communication function such as a conventional person- 
al compuler (PC), a workstation and a notebook PC. or 
a combination thereof. 

Hov/cver these components are exemplary given 
and It IS not intended that all of those components are 
necessarily indispensable components of this invention. 
Particularly because the hardware configuration de- 
scribed here IS required for operating a remote server 
(supporting server), the audio controller 21 , the amplifier 
22 the speaker 23 and the microphone 24 required for 
processing a voice are not the indispensable compo- 
nents Also the keyboard 6. the mouse 7 and the key- 
boardmousc coniroller 5 enabling direct input from the 
operator arc not the indispensable components when 
the server is solely remote controlled. 

The opciatinq system tn the side of the remote con- 
trolling rvichirc 2 10 may be implemented by one which 
suppons GUI mu ti window environment as a standard, 
such as WifiOjwi NT (d trademark of Microsoft), Win- 
dows 95 M iirtJcrTwirk of fv/licrosoft), Windows 3.x (a 
tradenrvif K ol Wtcrosoll) OS/2 ( a trademark of IBM). Ma- 
cOS (a tfrtdcfTnfk of ApDic). and X-WINDOW system (a 
traderrvifk of Vi') on AIX (a trademark of IBM), one 
which ic in cri.ir.:CiCf brisc environment, such as PC- 
DOS (a tr^idcfTLifK of IBM) and MS-DOS ( a trademark 
of Microsof.) h ^o^l time OS. such as OS/Open (a trade- 
mark of IBM) rtHd VxWorks(a trademark of Wind River 
Systems Inr t nnd OS which is installed in a network 
computer such javaOS as well as a chip card OS 
as described m the rtbove without being limited to any 
specific opcrrt inq system environment. 

The opcfrtinq svsicm in the supporting server side 
240 may be implcnr>cnted by one which supports GUI 
muiti-window environment as a standard, such as Win- 
dows NT (d I'Hdcnvirk of Microsoft). Windows 95 (a 
trademark of Microsoft}. Windows 3.x (a trademark of 
Microsoft). OS 2 m trademark of IBM). MacOS (a trade- 
mark of Apple) r.nd X-WINDOW system (a trademark 
of MIT) on AIX Id trademark of IBM), a real time OS. 
such as OS/ODcn tn trademark of IBM) and VxWorks(a 
trademark of V;ind R vcr Systems. Inc) and an OS which 
is installed m a network computer, such as JavaOS with- 
out being limited :o any specific operating system envi- 
ronment. 

Fig.2 is a diagram illustrating the operational condi- 
tion of the system in a preferred embodiment of this in- 
vention. In this embodiment, the portable information 
terminal 210 has an access to the supporting sender 240 
by a PHS function 

A connection request is sent from the portable in- 
formation terminal 210 to the supporting server 240. 

The supporting server 240 receives the connection 
request and notifies the portable information terminal 
210 that it can be connected. Fig.2 shows a state in 
which a remote controlling application on the portable 
information terminal 210 and a remote controlled appli- 
cation on the supporting server 240 has established a 



connection. 

In the figure. "PIPS' is an abbreviation of "PHS In- 
ternet Access Forum Standard" which is a communca- 
tlon method for a high speed wireless communication at 
5 32 Kbps with PHS. 

Fig.3 ts a functional block diagram explaining the 
system configuration of the portable information termi- 
nal 210 and the supporting server 240 in the preferred 
embodiment of this invention. In the figure, portable in- 

10 formation terminal 210 side includes an input informa- 
tion monitoring pari 303, an input information sending 
part 307, a rendering instruction receiving part 333, a 
rendering instruction storing part 335, a rendering in- 
struction analysing part 337 and a fogical screen image 

75 data storing part 339. 

On the other hand, the supporting server 240 side 
includes an input information receiving part 311 , an input 
information storing part 31 3, an input information ana- 
lysing pan 315, a window system 320, a rendering in- 

20 slruction storing part 327 and a rendering instruction 
sending part 329. 

The input information generating part 303 gener- 
ates input information to be described later based on a 
key input taking place by operating an input device such 

25 as a keyboard on the portable information terminal 210. 
The input information sending part 307 sends the input 
information to the supporting server 240. 

The input information receiving part 31 1 receives in- 
put information transmitted from the portable informa- 

30 lion terminal 210 side and stores the input information 
in the input information storing part 31 3 in the supporting 
server 240 side to be described later The input informa- 
tion storing part 31 3 temporarily stores input information 
to nnake the input information receiving part 311 and the 

35 input information analysing part 315 independently op- 
erable. 

The input information analysing part 315 monitors 
the input information to be stored in the input information 
storing part 313 of the supporting server side and anal- 

40 yses the input information stored in the input information 
storing part 313. The input information analysing part 
315 then converts it to a message (window message) in 
the form conforming to the window system installed in 
the supporting server 240 for delivery to the window sys- 

45 tem 320. 

In the preferred embodiment of this Invention, the 
window system includes a rendering instruction analys- 
ing part 321 , a rendering instruction monitoring part 323 
and a rendering driver 325. 

so Re-writing of the GUI screen caused by the window 
message is outputted as an image to a display device 
245 by an image rendering engine 321 and the render- 
ing driver 325 of the window svstem 320. The rendering 
instruction monitoring part 323 monitors all APIs called 

ss for re-writing the GUI screen of the supporting server, 
prepares a rendering instruction based on this, and per- 
forms a conversion processing of image data to be de- 
scribed later between the image rendering engine and 
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the rendering driver The rendering instruction nnonitof- 
ing part 323 also stores a rendering Instruction including 
the convened inrage data In the rendering instruction 
storing part 327 of the supporting server 240 side. 

The rendering instruction storing part 313 tempo- 
rarily stores a rendering instruction to make the render- 
ing Instruction monitoring part 323 and the rendering in- 
struction sending part 329 independently operable. 

The rendering instruction sending part 329 monitors 
to see that a rendering Instruction is stored in the ren- 
dering Instruction storing part 327 and, when detecting 
that a rendering instruction is stored in the rendering in- 
struction storing part 327. sends the rendering instruc- 
tion to the portable information terminal 210 side. 

The rendering Instruction receiving part 333 moni- 
tors transmission of a rendering instruction Irom the sup- 
pofimg server and stores the received rendering instruc- 
iKXi tn the rendering instruction storing pan 335 of the 
po^irtDic information terminal 210 side. 

The rendering instruction analysing part 327 moni- 
iu»b lu bce that a rendering Instruction is stored in the 
rctx>OTing instruction storing part 335 and composes an 
irrvigc vwhich is resulted from image conversion process 
lo be described later applied to the image generated in 
ihc window system of the supporting server by analys- 
ing tro eiofod rendering instruction Into a logical screen 
invigo ol bit map. By monitoring the change of the 
screen by a software timer or a window message hook 
Hnd gororaling a rendering instruction from the differ- 
ence H Simitar system can be constructed though the 
opefrtting speed is somehow sacrificed. 

A display region specifying part 341 specifies a re- 
gion in the screen 211 of the portable Information termi- 
nal 210 from the togical screen image of the bit map for 
output to the display screen 211. 

While each functional block shown in Fig.3 has 
been described in the above, it is a logical functional 
block and is not meant lo be Implemented in the form of 
a discrete hardware or a software. It can be implement- 
ed by a shared hardware or software. Also, it is not 
meant that all functional blocks shown in Flg.3 are In- 
dispensable components of this invention. For example, 
when the supporting server 240 Is customised to sup- 
port a remote controlling terminal, the rendering driver 
325 or the display screen 245 is a component which is 
not needed In this invention because it does not have to 
pertorm screen display by itself. 

Next, a procedure of the remote control in the pre- 
ferred embodiment of this Invention will be described 
with reference to the flow chart of Fig.4 to 1 0 and a sche- 
matic diagram of Fig 11 showing the operational condi- 
tion of the portable Inlormallon terminal 2 1 0 and the sup- 
porting server 240. Fig.4 and Flg.5 are flow chart show- 
ing the procedure of processing in the portable informa- 
tion terminal 210 side in the preferred embodiment of 
this invention. 

The operator starts up the portable information ter- 
minal 210 (block 401) and sends out a connection re- 



quest to the supponing server 240 using the PHS func- 
tion of the portable Information terminal 2l0 (block 403). 
When the connection is successful (block 405) and the 
supporting server 240 is ready (bkxk 411), information 

s Indicating the processing capability of the portable infor- 
matbn terminal is sent from the portable information ter- 
minal 21 0 to the supporting server 240 side (block 413). 
In the preferred embodiment of this inventbn, the 
processing capability information includes the resolu- 

10 tlon of the logical screen, the display capability of colour 
Image (number of bits Information per pcture element 
such as 256 colours, 1 6 colours and monochrome), col- 
our palette information and compression/decompres- 
sion capability Information, etc. 

IS When the rendering Instruction can be received 
(block 415). a rendering instruction of an initial screen 
is received from the supporting server 240 (block 417) 
and the received rendering Instruction is stored in the 
rendering instruction storing part 335 of the portable in- 

20 formation terminal 210 (bkxk 419). 

When reception of the rendering instruction has 
been completed (block 421), the rendering instruction 
analysing part 337 analyses the rendering instruction 
stored in the rendering instruction storing part 335 and 

25 generates an image which is resulted from an image 
conversion applied to the Image rendered on the GUI 
screen of the supporting server for rendering on the 
screen 211 of the portable information terminal 210 
(block 425). 

30 In the preferred embodiment of this Invention, a cer- 
tain region is cut out of the logical screen 213 on the 
memory as a display region for display as shown in Fig. 
11. The will be described later in this specification. 
The input information generating part 303 monitors 

35 input Information taking place by a key input on the key- 
board of the portable information terminal 210 (block 
426) and converts the key Input to a mouse key input 
(blocks 427. 429). 

In the preferred embodiment of this Invention, the 

^0 signal generated by the key Input Is converted by the 
Input Information generating part 303 to input informa- 
tion such as the type of input Information and the coor- 
dinate position where the Input Information is generated 
for delivery to the input information sending part 307 as 

45 shown In Fig. 12. A sample of input information in the 
preferred embodiment of this invention is shown In Fig. 
13. The input Information sending part 307 sends this 
input information to the supporting server 240 side. 
The input information may be sent to the supporting 

so server 240 with compression or encryption and then de- 
compressed or de-encrypted for use In the supporting 
server 240 side. 

When the logical screen is updated or the mouse is 
moved in the logical screen (blocks 435, 437), the dis- 

ss play region specifying part 341 calculates a screen off- 
set position (block 439) and renders a part of the logical 
screen specified by the calculation In the display screen 
211 (block 441). Also, the mouse pointers are composed 
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(block 443). 

In the preferred embodiment of this invention, the 
size of the region 215 to be cut out as a display region 
is determined from the size of the logical screen 21 3 on 
the memory, the size of the display screen 211 of the 
portable information terminal 210 and position informa- 
tion of the mouse pointer as shown in Fig. 11. 

Specifically, by putting the start point (upper left co- 
ordinate position) of the cut out region 215 as (ox, oy), 
the size of the logical screen 21 3 on the memory as (sx. 
sy). the size of the display screen 211 of the portable 
information terminal 21 0 as (wx, wy) and the coordinate 
position of the mouse pointer as (px, py), 

ox and oy are determined by: 

ox = px (sx • wx)/(sx - 1) 



oyrpy (sy • wy)/(sy ■ 1) 

and a region (wx, wy) having start points ox and oy is 
determined to be a cut out region 215. However, this is 
a mere example and the position of the mouse pointer 
may be always at the centre (excluding the periphery) 
of the display screen. 

In this case, ox and oy are determined by; 

ox = px - wx/2 



oy = py - wy/2 

(provided ox = 0 when ox < 0 

ox = sx - wx when ox > sx - wx 

oy = 0 when oy < 0 

oy = sy - wy when oy > sy - wy) 

and a region having ox and oy is determined to be the 
cut out regbn 215. 

Fig.6 to Fig. 10 are flow charts showing the process- 
ing procedure of the supporting server 240 side in the 
preferred embodiment of this invention. 

When the supporting server 240 is started (block 
501 ), the supporting server 240 determines whether or 
not there is a connection request from the portable in- 
formation terminal (block 503). 

When there is a connection request, the shell pro- 
gram is started to start the logical window system (block 
507). In the preferred embodiment of this invention, the 
supporting server 240 can run a plurality of shell proc- 
esses and enables connection to a plurality of portable 
information terminals to allow a parallel processing of 



shell processes. 

"logical window system' as used here means a win- 
dow system in which an input from a physical mouse or 
keyboard is neglected and output to a physical video de- 

5 vice is disabled. Because such logical window system 
does not access to a physical device, a plurality of such 
systems can be active simultaneously 

Then, processing capability information sent from 
the portable information terminal 210 is received (block 

^0 509), and the rendering instruction nrranitoring part 323, 
the rendering instruction sending part 329, the input in- 
formation receiving part 311 and the input information 
analysing part 315 are each activated (blocks 511, 513. 
514,515). 

^5 In the preferred embodiment of this invention, when 
the supporting server 240 starts, it re-renders the GUI 
screen of the supponmg server 240 (bkxk 512) and 
sends it to the portable information terminal 210 as a 
rendering instruction. 
20 When the end of operation is detected (block 516), 
the logical window system and the shell process are 
ended (block 517, 518). 

Fig.7 is a flow chart showing a processing proce- 
dure of the rendering instruction monitoring part 323. 

2S The rendering instruction monitoring part 323 inter- 
venes between the GUI of the window system 320 and 
the rendering driver 325 and can behave as if it is the 
rendering driver 325 relative to the image rendering en- 
gine 321 while it behaves as if it is the image rendering 

30 engine 321 relative to the rendering driver 325. 

The rendering instruction monitoring part 323 mon- 
itors between the image rendering engine and the ren- 
dering driver, monitors all API's called for re-writing the 
GUI screen of the supporting server (block 521), pre- 

55 pares a rendering instruction based on this (block 523), 
and stores it in the rendering instruction storing part 327 
of the supporting server 240 after image conversion 
(block 525. 527). Fig. 1 5 is an example of data of a typical 
rendering instruction in the preferred embodiment of this 

40 invention. Incidentally, if the resolution of the output de- 
vice of the portable inlormation terminal is sufficiently 
high, an output may be directly provided to the output 
device of the portable information terminal by omitting 
the process of rendering tor the logical screen. 

45 In the preferred embodiment of this invention, an 
image conversion is performed according to the 
processing capability specifying information sent from 
the portable information terminal 2l0. In the example of 
Fig. 1 1 , the portable information terminal 21 0 notifies the 

so supporting server 240 that an image of two gradations 
of white and black is handled. 

Fig. 1 6 shows a grey scale conversion from a colour 
image to mufti gradations of white and black while Fig. 
17 shows a dithering conversion from multi gradations 

55 of white and black to two gradations of white and black. 
The dithering conversion may be replaced by optimising 
with the error diffusion method known in the art. By per- 
forming various conversions which the portable informa- 
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lion (erminal 210 requires in the supporting server 240 
side the lo;^d of the portable information terminal 210 
Cfin be reduced and the communication volume be- 
tween the server 240 and the portable information ter- 
minal 210 can be reduced. 5 

The convened rendering instruction may be further 
compressed or encrypted according to the processing 
ccpat)ility specifying information sent from the portable 
information terminal 21 0 and sent to the portable infor- 
mntion terminal 210 where it may be decompressed for io 
use 

Fig 5 IS a flow chart showing a processing proce- 
dure of the rendering instruction sending part 329. The 
rendering instruction sending part 329 monitors to see 
that a rendering instruction is stored in the rendering in- 
struciion storing part 327 (block 535). When it Is detect- 
ed that the rcrdc^ing instruction has been stored in the 
rendering msiiuciton storing part 327, the rendering in- 
struction sending part 329 sends the rendering Instruc- 
tion 13 itic portable inlormation terminal 210 side (block 20 
537) Tfiib piuceOuie is continued until the end of 
process ng (bkxk 537) and. upon detection of the end 
of process nq the rendering instruction sending part 
329 IS dc.iciiv.itcd (block 541). 

Fig 9 IS a fio^ chort showing a processing proce- 2S 
dure of the input infcrnr^ation receiving part 311. The in- 
put inforrrviiion rccorving part 311. upon receiving oper- 
ation Stan input information from the portable informa- 
tion terminni 21 0 determines that input information can 
be received (t^toci^ 551 ). receives input information sent 30 
from the portable information terminal 210 side (block 
553) and stores nc input information In the input Infor- 
mation slor nq pHl 31 3 of the supporting server 240 side 
(block 555) In input mfornnation receiving part 311 also, 
the procedure is continued until the end of operation 35 
(block 557) and upon detection of the end of operation, 
the input information receiving part 311 is deactivated 
(block 459) 

The input inlormation analysing part 315 monitors 
to see that input information is stored in the input infor- ^0 
mation storing part 31 3 as shown in Fig. 10 (block 561) 
and analyses the input information stored In the Input 
information storing part 31 3 (block 563). In the preferred 
embodiment cf tr is invention, the input information an- 
alysing pan 315 analyses the received Input information 45 
and converts M to a message of a form conforming to 
the window system installed In the supporting server for 
delivery to the window system 320 via a journal playback 
hook 307 (block 571). 

The journal playback hook 397 Is usually used to- 50 
gether with a journal record hook. The journal record 
hook can record a window message generated by an 
operator input and reproduce the recorded window mes- 
sage by the journal playback hook. 

In the preferred embodiment of this inventbn, the ss 
function of the journal playback hook is utilised. By de- 
livering a window message generated in the input infor- 
mation analysing part to the journal playback hook 307. 



the window svstem 320 can handle it as a window mes- 
sage generated within the window system. The window 
message delivered to the window system 320 is inter- 
preted by the window system 320 to determine what in- 
put was given to what application and causes the GUI 
screen to be re- written. This re- writing of the GUI screen 
caused by the window message is outputted to the dis- 
play device 245 as an image by the Image rendering 
engine 321 and the rendering driver 325 of the window 
svstem 320. 

In the input Information analysing part also, this pro- 
cedure is continued until the end of operation (block 
565) and. upon detection of the end of operation, the 
input Information analysing part 315 notifies each part 
of the end of operation (block 567) and is then deacti- 
vated (block 569). 

As described in the above, according to this inven- 
tion, a system is provided which Is capable of executing 
a general purpose OS as used in a conventional PC and 
a high level application operating on such OS in a ma- 
chine having limited resources. 

In one mode of this invention, a small size portable 
terminal of a low cost and providing a high function is 
provided. 

In one mode of this invention, a portable information 
terminal is provided which can execute an application 
used In home or office. 

In one mode of this Invention, a portable information 
terminal having a low probability of losing data Is pro- 
vided. 

In one mode of this Invention, it Is possible to reduce 
the work of Installing a remote control software which 
was generated in the side of remote controlling terminal 
for enabling a consolidated control of a system. 

In one mode of this Invention, a system is provided 
which is not affected by the type of a remote controlling 
terminal for realising a common operabillty 

In one mode of this invention, it is possible to reduce 
the usage of resources of a remote controlling terminal 
for reducing the hardware requirement to enable a gen- 
eral purpose OS and a general purpose application to 
be used. 

In one mode of this invention, a high speed remote 
control system Is provided which reduces the volume of 
communication data between a remote controlling ma- 
chine and a remote controlled machine in remote control 
operation. 

In one mode of this invention, a remote control 
svstem Is provided in which data is transmitted in a form 
optimum to a remote controlling machine In performing 
a remote control. 

In one mode of this invention, a remote control sys- 
tem is provided which can simultaneously support a plu- 
rality of remote controlling machines In performing a re- 
mote control. 
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Claims 

1 . A method or any one of system, a server (247) or a 
recording medium (20) having a program code for 
insUuciing said server for remote controlling re- 
sources retained by a server existing on a network 
from a terminal (215) which has an input device 
(301) and a display device (220), comprising; 

(a) receiving or means for receiving (31 1 ) or in- 
structing receiving respectively the input infor- 
mation transmitted from said terminal side 
(215). 

(b) analysing or means for analysing (315) or 
instructing analysing respectively the input in- 
tormation. 

(c) generating or means for generating (320) or 
intiiuciing generating respectively first render- 
ing iifirtyc Crtta consisting of a first number of 
bits per p<ture element based on the content 
of the rtrvityscd input information, 

(d) converting or means for converting or in- 
slf jci ng converting respectively said first ren- 
dc'ing image data to second rendering image 
dHiH consisting of a second number of bits per 
pirturo rlnmcnt less than the first number of 
bits rind 

(e) Irrtnsmiiiing or means for transmitting (329) 
or instructing transmitting respectively a ren- 
dering instruction including said second render- 
ing image from said server side (247) to said 
terminal side (215). 

2. A method system server or recording medium as 
claimed in claim 1 including analysing or means for 
analysing (337) or analysing respectively the ren- 
dering instruction transmitted from the server side 
on said terminal side (215). and 

generating or means lor generating or generating 
respectively image data to be displayed in a display 
screen (220) ol said terminal (215) according to the 
content ol the analysed rendering instruction (337). 

3. A method system server or recording medium or a 
program code respectively as claimed in claim 1 in- 
cluding starting or means for starting (505) respec- 
tively a shell process in response to a connection 
request from a lirst terminal of a plurality of termi- 
nals. 

4. A method system, sen/er (247) or recording medi- 
um (20) as claimed in any of claims 1 to 3 and in- 
cluding; 

receiving or means for receiving (311) or receiving 



respectively a processing capability specifying in- 
formation transmitted from said terminal (215). 

5. A method, system, server (247) or recording medi- 
f um (20) having a program code for instructing said 

server as claimed in any previous claim in which the 
processing capability specifying information is ei- 
ther one of; 

10 (a) maximum resolution information of a logical 

screen. 

(b) maximum resolution information of a phys- 
ical screen, 

(c) bits per picture element information. 
IS (d) colour palette informatbn. 

(e) compression/decompression capability in- 
formation, of said terminal. 

6. A method for specifying a display region of a size 
20 of (wx. wy) to be displayed on a display screen from 

image data constituting a logical screen having a 
size of (sx, sy) stored in a portable information ter- 
minal, characterised in that the region of the size of 
(wx. v\/y) is specified as a display region starting 
2S from a starting point which is defined as; 

ox = px(sx - vw)/((sx - 1) 

30 

oy = py(sy - wy)/(sy - 1 ) 

where (px. py) is a coordinate position of a mouse 
pointer of the portable information terminal. 

35 
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